package trasfamilia.dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Collection;

import trasfamilia.excepcion.DAOExcepcion;
import trasfamilia.modelo.Servicio;
import trasfamilia.util.ConexionBD;

public class ServicioDAO extends BaseDAO {

	public Collection<Servicio> validarPorNombre(String nombre)
			throws DAOExcepcion {
		String query = "select idServicio,nombre,descripcion,costoPersona from servicio where nombre=?";
		Collection<Servicio> lista = new ArrayList<Servicio>();
		Connection con = null;
		PreparedStatement stmt = null;
		ResultSet rs = null;
		try {
			con = ConexionBD.obtenerConexion();
			stmt = con.prepareStatement(query);
			stmt.setString(1,nombre);
			rs = stmt.executeQuery();
			while (rs.next()) {
				Servicio vo = new Servicio();
				vo.setIdServico(rs.getInt("idServicio"));
				vo.setNombre(rs.getString("descripcion"));
				vo.setCostoPersona(rs.getDouble("costopersona"));
				lista.add(vo);
			}
		} catch (SQLException e) {
			System.err.println(e.getMessage());
			throw new DAOExcepcion(e.getMessage());
		} finally {
			this.cerrarResultSet(rs);
			this.cerrarStatement(stmt);
			this.cerrarConexion(con);
		}
		System.out.println(lista.size());
		return lista;
	}

	public Servicio insertar(Servicio vo) throws DAOExcepcion {
		String query = "insert into servicio(idServicio,nombre,descripcion,costoPersona,Estado) values (?,?,?,?,?)";
		Connection con = null;
		PreparedStatement stmt = null;
		ResultSet rs = null;
		try {
			con = ConexionBD.obtenerConexion();
			stmt = con.prepareStatement(query);
			stmt.setInt(1, vo.getIdServico());
			stmt.setString(2, vo.getNombre());
			stmt.setString(3, vo.getDescripcion());
			stmt.setDouble(4, vo.getCostoPersona());
			stmt.setString(5, vo.getEstado());
			int i = stmt.executeUpdate();
			if (i != 1) {
				throw new SQLException("No se pudo insertar");
			}
			// Obtener el ultimo id
			/*int id = 0;
			query = "select last_insert_id()";
			stmt = con.prepareStatement(query);
			rs = stmt.executeQuery();
			if (rs.next()) {
				id = rs.getInt(1);
			}
			vo.setIdCategoria(id);*/

		} catch (SQLException e) {
			System.err.println(e.getMessage());
			throw new DAOExcepcion(e.getMessage());
		} finally {
			this.cerrarResultSet(rs);
			this.cerrarStatement(stmt);
			this.cerrarConexion(con);
		}
		return vo;
	}

	public Servicio obtener(int idServicio) throws DAOExcepcion {
		Servicio vo = new Servicio();
		Connection con = null;
		PreparedStatement stmt = null;
		ResultSet rs = null;
		try {
			String query = "select idServicio,nombre,descripcion,costoPersona,case when Estado='A'then 'Activo' else 'Inactivo' End as Estado from servicio where idservicio=?";
			con = ConexionBD.obtenerConexion();
			stmt = con.prepareStatement(query);
			stmt.setInt(1, idServicio);
			rs = stmt.executeQuery();
			if (rs.next()) {
				vo.setIdServico(rs.getInt(1));
				vo.setNombre(rs.getString(2));
				vo.setDescripcion(rs.getString(3));
				vo.setCostoPersona(rs.getDouble(4));
				vo.setEstado(rs.getString(5));
			}
		} catch (SQLException e) {
			System.err.println(e.getMessage());
			throw new DAOExcepcion(e.getMessage());
		} finally {
			this.cerrarResultSet(rs);
			this.cerrarStatement(stmt);
			this.cerrarConexion(con);
		}
		return vo;
	}

	public void eliminar(int idServicio) throws DAOExcepcion {
		String query = "delete from servicio WHERE idServicio=?";
		Connection con = null;
		PreparedStatement stmt = null;
		try {
			con = ConexionBD.obtenerConexion();
			stmt = con.prepareStatement(query);
			stmt.setInt(1, idServicio);
			int i = stmt.executeUpdate();
			if (i != 1) {
				throw new SQLException("No se pudo eliminar");
			}
		} catch (SQLException e) {
			System.err.println(e.getMessage());
			throw new DAOExcepcion(e.getMessage());
		} finally {
			this.cerrarStatement(stmt);
			this.cerrarConexion(con);
		}
	}

	public Servicio actualizar(Servicio vo) throws DAOExcepcion {
		String query = "update servicio set nombre=?,descripcion=?,costopersona=?,estado=? where idservicio=?";
		Connection con = null;
		PreparedStatement stmt = null;
		try {
			con = ConexionBD.obtenerConexion();
			stmt = con.prepareStatement(query);
			stmt.setString(1, vo.getNombre());
			stmt.setString(2, vo.getDescripcion());
			stmt.setDouble(3, vo.getCostoPersona());
			stmt.setString(4, vo.getEstado());
			stmt.setInt(5, vo.getIdServico());
			int i = stmt.executeUpdate();
			if (i != 1) {
				throw new SQLException("No se pudo actualizar");
			}
		} catch (SQLException e) {
			System.err.println(e.getMessage());
			throw new DAOExcepcion(e.getMessage());
		} finally {
			this.cerrarStatement(stmt);
			this.cerrarConexion(con);
		}
		return vo;
	}

	public Collection<Servicio> listar() throws DAOExcepcion {
		Collection<Servicio> c = new ArrayList<Servicio>();
		Connection con = null;
		PreparedStatement stmt = null;
		ResultSet rs = null;
		try {
			con = ConexionBD.obtenerConexion();
			String query = "select idServicio,nombre,descripcion,costoPersona,case when Estado='A'then 'Activo' else 'Inactivo' End as Estado from servicio order by idServicio";
			
			stmt = con.prepareStatement(query);
			rs = stmt.executeQuery();
			while (rs.next()) {
				Servicio vo = new Servicio();
				vo.setIdServico(rs.getInt("idServicio"));
				vo.setNombre(rs.getString("nombre"));
				vo.setDescripcion(rs.getString("descripcion"));
				vo.setCostoPersona(rs.getDouble("costoPersona"));
				vo.setEstado(rs.getString("Estado"));
				c.add(vo);
			}

		} catch (SQLException e) {
			System.err.println(e.getMessage());
			throw new DAOExcepcion(e.getMessage());
		} finally {
			this.cerrarResultSet(rs);
			this.cerrarStatement(stmt);
			this.cerrarConexion(con);
		}
		return c;
	}

}
